# МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ «ЛЬВІВСЬКА ПОЛІТЕХНІКА»

Інститут комп'ютерних технологій, автоматики та метрології кафедра "Електронних обчислювальних машин"



# Звіт

3 лабораторної роботи  $N^{\circ}2$ 

3 дисципліни: «Моделювання комп'ютерних систем»

На тему: «Структурний опис цифрового автомата Перевірка роботи автомата за допомогою стенда Elbert V2 – Spartan3A FPGA»

Варіант 27

Виконав: ст. гр. КІ-202

Хомин П.Л.

Козак Н.Б

#### Львів 2024

### ЛАБОРАТОРНА РОБОТА №2

# Структурний опис цифрового автомата Перевірка роботи автомата за допомогою стенда Elbert V2 – Spartan3A FPGA

**Мета роботи:** На базі стенда реалізувати цифровий автомат світлових ефектів

# Вхідні параметри

| Стан# | LED_0 | LED_1 | LED_2 | LED_3 | LED_4 | LED_5 | LED_6 | LED_7 |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0     | 1     | 1     | 0     | 0     | 0     | 0     | 0     | 0     |
| 1     | 0     | 1     | 1     | 0     | 0     | 0     | 0     | 0     |
| 2     | 0     | 0     | 1     | 1     | 0     | 0     | 0     | 0     |
| 3     | 0     | 0     | 0     | 1     | 1     | 0     | 0     | 0     |
| 4     | 0     | 0     | 0     | 0     | 1     | 1     | 0     | 0     |
| 5     | 0     | 0     | 0     | 0     | 0     | 1     | 1     | 0     |
| 6     | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |
| 7     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 1     |

- Пристрій повинен використовувати 12MHz тактовий сигнал від мікроконтролера IC1 і знижувати частоту за допомогою внутрішнього подільника. Мікроконтролер IC1 є частиною стенда Elbert V2 Spartan 3A FPGA. Тактовий сигнал заведено нв вхід LOC = P129 FPGA (див. Додаток 1).
- Інтерфейс пристрою повинен мати вхід синхронного скидання (RESET).
- Інтерфейс пристрою повинен мати вхід керування режимом роботи (MODE):
  - $\circ$  Якщо MODE=0 то стан пристрою інкрементується по зростаючому фронту тактового сигналу пам'яті станів (0->1->2->3->4->5->6->7->0...).
  - Якщо *MODE=1* то стан пристрою декрементується по зростаючому фронту тактового сигналу пам'яті станів (0->7->6->5->4->3->2->1->0...).
- Інтерфейс пристрою повинен мати однорозрядний вхід керування швидкістю роботи(SPEED):
  - Якщо SPEED=0 то автомат працює зі швидкістю, визначеною за замовчуванням.
  - $\circ$  Якщо *SPEED=1* то автомат працює зі швидкістю, <u>В 4 РАЗИ ВИЩОЮ</u> ніж в режимі (*SPEED= 0*).
- Для керування сигналом MODE використати будь який з 8 DIP перемикачів (див.
   Додаток 1).
- Для керування сигналами RESET/SPEED використати будь якІ з PUSH BUTTON кнопок (див. Додаток – 1).

# Порядок виконання лабораторної роботи.

- Інтерфейс пристрою та функціонал реалізувати згідно отриманого варіанту завдання.
- Логіку переходів реалізувати з використанням мови опису апаратних засобів.
- Логіку формування вихідних сигналів реалізувати з використанням мови опису апаратних засобів.
- Згенерувати символи для описів логіки переходів та логіки формування вихідних сигналів.

- Зінтегрувати всі компоненти логіку переходів логіку формування вихідних сигналів та пам'ять станів в єдину систему. Пам'ять станів реалізувати за допомогою графічних компонентів з бібліотеки.
- Промоделювати роботу окремих частин автомата та автомата вцілому за допомогою симулятора ISim.
- Інтегрувати створений автомат зі стендом додати подільник частоти для вхідного тактовового сигналу призначити фізичні виводи на FPGA.
- Згенерувати файал та перевірити роботу за допомогою стенда Elbert V2 Spartan3A FPGA.
- Підготувати і захистити звіт.

#### Виконання лабораторної роботи:

| MOD | CURR_STATE( | CURR_STATE( | CURR_STATE( | NEXT_STATE( | NEXT_STATE( | NEXT_STATE( |
|-----|-------------|-------------|-------------|-------------|-------------|-------------|
| Е   | 2)          | 1)          | 0)          | 2)          | 1)          | 0)          |
| 0   | 0           | 0           | 0           | 0           | 0           | 0           |
| 0   | 0           | 0           | 1           | 0           | 0           | 1           |
| 0   | 0           | 1           | 0           | 0           | 1           | 0           |
| 0   | 0           | 1           | 1           | 0           | 1           | 1           |
| 0   | 1           | 0           | 0           | 1           | 0           | 0           |
| 0   | 1           | 0           | 1           | 1           | 0           | 1           |
| 0   | 1           | 1           | 0           | 1           | 1           | 0           |
| 0   | 1           | 1           | 1           | 1           | 1           | 1           |
| 1   | 0           | 0           | 0           | 0           | 0           | 0           |
| 1   | 0           | 0           | 1           | 0           | 0           | 0           |
| 1   | 0           | 1           | 0           | 0           | 0           | 1           |
| 1   | 0           | 1           | 1           | 0           | 1           | 0           |
| 1   | 1           | 0           | 0           | 0           | 1           | 1           |
| 1   | 1           | 0           | 1           | 1           | 0           | 0           |
| 1   | 1           | 1           | 0           | 1           | 0           | 1           |
| 1   | 1           | 1           | 1           | 1           | 1           | 0           |

Рис.1.1 (Логіка переходів для всіх станів автомата)

Логіка переходів на мові VHDL

 $NEXT\_STATE(0) = not(CURR\_STATE(0));$ 

NEXT\_STATE(1) = ((not(MODE) and not(CURR\_STATE(1)) and CURR\_STATE(0)) or (not(MODE) and CURR\_STATE(1) and not(CURR\_STATE(0))) or (MODE and not(CURR\_STATE(1)) and not(CURR\_STATE(0))) or (MODE and CURR\_STATE(1) and CURR\_STATE(0)));

NEXT\_STATE(2) <= ((not(MODE) and CURR\_STATE(2) and not(CURR\_STATE(1))) or (CURR\_STATE(2) and CURR\_STATE(1) and not(CURR\_STATE(0))) or (MODE and CURR\_STATE(2) and CURR\_STATE(0)) or (not(MODE) and not(CURR\_STATE(2)) and CURR\_STATE(1) and CURR\_STATE(0)) or (MODE and not(CURR\_STATE(2)) and not(CURR\_STATE(1)) and not(CURR\_STATE(0)));

#### Логіка формування вихідних сигналів

OUT\_BUS(0) <= (not(IN\_BUS(2)) and not(IN\_BUS(1)) and not(IN\_BUS(0))) after 1 ns;

 $OUT_BUS(1) \le (not(IN_BUS(2)))$  and  $not(IN_BUS(1)))$  after 1 ns;

OUT\_BUS(2) <= ((not(IN\_BUS(2)) and not(IN\_BUS(1)) and IN\_BUS(0)) or (not(IN\_BUS(2)) and IN\_BUS(1) and not(IN\_BUS(0)))) after 1 ns;

 $OUT_BUS(3) \le (not(IN_BUS(2)) \text{ and } IN_BUS(1)) \text{ after } 1 \text{ ns};$ 

OUT\_BUS(4) <= ((not(IN\_BUS(2)) and IN\_BUS(1) and IN\_BUS(0)) or (IN\_BUS(2) and not(IN\_BUS(1)) and not(IN\_BUS(0)))) after 1 ns;

 $OUT_BUS(5) \le (IN_BUS(2) \text{ and } not(IN_BUS(1))) \text{ after } 1 \text{ ns};$ 

OUT\_BUS(6) <= ((IN\_BUS(2) and not(IN\_BUS(1)) and IN\_BUS(0)) or (IN\_BUS(2) and IN\_BUS(1) and not(IN\_BUS(0)))) after 1 ns;

 $OUT_BUS(7) \le (IN_BUS(2) \text{ and } IN_BUS(1)) \text{ after } 1 \text{ ns};$ 



Рис.1.2 (Згенеровані схематичні схеми)



Рис.1.3 (Інтеграція всіх створених компонентів разом з пам'ятю станів автомата)



Рис.1.4 (Автомат світлових сигналів та подільник тактового сигналу)





Рис.1.5 (Результати симуляції логіки переходів в ISim)



Рис.1.6 (Результати симуляції логіки вихідних сигналів в ISim)



Рис.1.7 (Результати симуляції автомата (MODE = 0, RESET = 0))



Puc.1.8 (Результати симуляції автомата (MODE = 1, RESET = 0))



Рис.1.9 (Результати симуляції автомата (MODE = 0, RESET = 1))



Puc.2.1 (Результати симуляції автомата (MODE = 1, RESET = 1))



Puc.2.1.1 (Результати симуляції фінальної схеми (MODE = 0, RESET = 0, SPEED = 0))



Puc.2.1.2 (Результати симуляції фінальної схеми (MODE = 0, RESET = 0, SPEED = 1))

#### Реалізація Test Brench



Рис.2.2 (Часова діаграма)

MODE = 0 OR RESET = 1 RESET = 1 MODE = 1 and RESET = 0 MODE = 0 and MODE = 0 and RESET = 0 RESET = 0 MODE = 1 and RESET = 0 MODE = 1 or RESET = 1 RESET = 1 MODE = 0 and RESET = 0 MODE = 1 and RESET = 0 RESET = 1 MODE = 1 and RESET = 0 RESET = 1 RESET = 1 RESET = 1 MODE = 0 and RESET = 0 MODE = 1 and RESET = 9 MODE = 1 and RESET = 0 MODE = 0 and RESET = 0 MODE = 1 and RESET = 0 MODE = 0 and RESET = 0 MODE = 0 and RESET = 0

Рис.2.3 (Консоль під час тестування)

Рис.2.4 (Граф переходів автомата між станами)

```
4 CONFIG VCCAUX = "3.3";
 5
   # Clock 12 MHz
 6
   NET "CLOCK"
                     LOC = P129 | IOSTANDARD = LVCMOS33 | PERIOD = 12MHz;
 7
 8
 9
   10
                          T.E.D.
11
   12
     NET "OUTPUT(0)"
                     LOC = P46 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
13
     NET "OUTPUT (1)"
                    LOC = P47 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
14
                    LOC = P48 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
     NET "OUTPUT(2)"
15
                     LOC = P49 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
16
     NET "OUTPUT (3)"
                     LOC = P50 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
     NET "OUTPUT (4)"
17
     NET "OUTPUT (5)"
                     LOC = P51 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
18
     NET "OUTPUT (6)"
                     LOC = P54 | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
19
    NET "OUTPUT (7)"
                     LOC = P55
                            | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
20
21
DP Switches
23 #
25
    NET "MODE"
               LOC = P70 | PULLUP | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
26
27
     28
29 #
                        Switches
31
    NET "RESET"
                LOC = P80 | PULLUP | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
32
    NET "SPEED"
                 LOC = P79 | PULLUP | IOSTANDARD = LVCMOS33 | SLEW = SLOW | DRIVE = 12;
33
34
```

Рис.2.2 (Призначення фізичних входів та виходів)

#### Висновок:

В ході виконання цієї лабораторної роботи я реалізував на базі стенда Elbert V2 – Spartan3A FPGA цифровий автомат світлових ефектів згідно заданих вимог.